home *** CD-ROM | disk | FTP | other *** search
/ The CICA Windows Explosion! / The CICA Windows Explosion! - Disc 2.iso / programr / eckelt01.zip / 11 / FRAMIS.CPP next >
C/C++ Source or Header  |  1995-02-23  |  3KB  |  89 lines

  1. // File from page 485 in "Thinking in C++" by Bruce Eckel
  2. //////////////////////////////////////////////////
  3. // From the compressed package ECKELT01.ZIP 2/21/95
  4. // Copyright (c) Bruce Eckel, 1995 
  5. // Source code file from the book "Thinking in C++", 
  6. // Prentice Hall, 1995, ISBN: 0-13-917709-4
  7. // All rights reserved EXCEPT as allowed by the following 
  8. // statements: You may freely use this file for your own 
  9. // work, including modifications and distribution in 
  10. // executable form only. You may copy and distribute this 
  11. // file, as long as it is only distributed in the complete 
  12. // (compressed) package with the other files from this 
  13. // book and you do not remove this copyright and notice. 
  14. // You may not distribute modified versions of the source 
  15. // code in this package. This package may be freely placed 
  16. // on bulletin boards, internet nodes, shareware disks and 
  17. // product vendor disks. You may not use this file in 
  18. // printed media without the express permission of the 
  19. // author. Bruce Eckel makes no 
  20. // representation about the suitability of this software 
  21. // for any purpose. It is provided "as is" without express 
  22. // or implied warranty of any kind. The entire risk as to 
  23. // the quality and performance of the software is with 
  24. // you. Should the software prove defective, you assume 
  25. // the cost of all necessary servicing, repair, or 
  26. // correction. 
  27. // If you think you've found an error, please 
  28. // email all modified files with loudly commented changes 
  29. // to: eckel@aol.com (please use the same 
  30. // address for non-code errors found in the book).
  31. //////////////////////////////////////////////////
  32.  
  33. //: FRAMIS.CPP -- Local overloaded new & delete
  34. #include <stddef.h> // Size_t
  35. #include <fstream.h>
  36. ofstream out("framis.out");
  37.  
  38. class framis {
  39.   char c[10];
  40. public:
  41.   framis() { out << "framis()\n"; }
  42.   ~framis() { out << "~framis() ... "; }
  43.   void* operator new(size_t);
  44.   void operator delete(void*);
  45. };
  46.  
  47. const psize = 100; // Number of frami allowed
  48. unsigned char pool[psize * sizeof(framis)];
  49. // Allocation map:
  50. unsigned char alloc_map[psize] = {0};
  51.  
  52. // Size is ignored -- assume a framis object
  53. void* framis::operator new(size_t) {
  54.   for(int i = 0; i < psize; i++)
  55.     if(!alloc_map[i]) {
  56.       out << "using block " << i << " ... ";
  57.       alloc_map[i] = 1; // Mark it used
  58.       return pool + (i * sizeof(framis));
  59.     }
  60.   out << "out of memory" << endl;
  61.   return 0;
  62. }
  63.  
  64. void framis::operator delete(void* m) {
  65.   if(!m) return; // Check for null pointer
  66.   // Assume it was created in the pool
  67.   // Calculate which block number it is:
  68.   unsigned long block = (unsigned long)m
  69.     - (unsigned long)pool;
  70.   block /= sizeof(framis);
  71.   out << "freeing block " << block << endl;
  72.   // Mark it free:
  73.   alloc_map[block] = 0;
  74. }
  75.  
  76. main() {
  77.   framis* f[psize];
  78.   for(int i = 0; i < psize; i++)
  79.     f[i] = new framis;
  80.   new framis; // Out of memory
  81.   delete f[10];
  82.   f[10] = 0;
  83.   // Use released memory:
  84.   framis* x = new framis;
  85.   delete x;
  86.   for(int j = 0; j < psize; j++)
  87.     delete f[j]; // Delete f[10] OK
  88. }
  89.